public class Test1 {
    //leetcode 面试题 17.16 按摩师
    public int massage(int[] nums) {
        int n = nums.length;
        if (n == 0) return 0;
        int[] f = new int[n]; //f表示以i位置为结尾的且当前位置预约时候的最长预约时间
        int[] g = new int[n]; //g表示以i位置为结尾的且当前位置不预约时候的最长预约时间
        f[0] = nums[0]; g[0] = 0;
        for (int i = 1; i < n; i++) {
            f[i] = g[i-1] + nums[i];
            g[i] = Math.max(f[i-1],g[i-1]);
        }
        return Math.max(f[n-1],g[n-1]);
    }
}
